package algorithm.sort;


import java.util.Arrays;

/**
 * 冒泡排序算法:
 * 1，前后两个数做比较，排好序后，拿最大值跟后面的数比较，这样第一轮过后就能找到数组中的最大数；
 * 2，再重复就能找到次大数，以此类推。
 */
public class BubbleSortTest {

    public static void main(String[] args) {
        int[] arr = {6,3,8,2,9,1,4};
        sort(arr);
        System.out.println("result arr = " + Arrays.toString(arr));
    }

    /**
     * 冒泡排序
     * @return
     */
    public static void sort(int[] arr){
        // 如果有某一轮没有置换过元素，可提前结束程序
        boolean change = false;
        for(int i = 0; i < arr.length; i++){
            System.out.println("arr = " + Arrays.toString(arr));
            change = false;
            for(int j = 0; j < arr.length - i - 1; j++){
                if(arr[j] > arr[j + 1]){
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                    change = true;
                }
            }
            if(!change) return;
        }
    }

}
